* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

.app {
  background-color: #282c34;
  height: 100vh;
  display: flex;
  flex-direction: column;
}

.header {  
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 16px;

  border-bottom: 1px solid red;
}

.variant-node {
  color: white;
  padding: 8px;
  border-width: 1px;
  border-style: solid;
}

.variant-node:hover {
  cursor: pointer;
}

.content {
  flex-grow: 1;
  display: flex;
}

.drop-place, .serialize-place {
  height: 100%;
  width: 50%;
}

.drop-place {
  border-right: 1px solid red;
}

.serialize-place {
  color: white;
  padding: 16px;
  height: calc(100vh - 72px);
  overflow: auto;
}

.canvas {
  height: 100%;
}

.button {
  background: rgb(60, 60, 60);
	font-size: 14px;
	padding: 5px 10px;
	border: none;
	color: white;
	outline: none;
	margin: 2px;
	border-radius: 3px;
}

.button:hover {
  background: rgb(0, 192, 255);
	cursor: pointer;
}
